package com.leetcode_Onequestion;

import java.util.*;

/**
 * @Author jsh
 * @Date 2022/4/13 20:35
 * @Version 1.0
 */

/*
* 实现RandomizedSet 类：
    RandomizedSet() 初始化 RandomizedSet 对象
    bool insert(int val) 当元素 val 不存在时，向集合中插入该项，并返回 true ；否则，返回 false 。
    bool remove(int val) 当元素 val 存在时，从集合中移除该项，并返回 true ；否则，返回 false 。
    int getRandom() 随机返回现有集合中的一项（测试用例保证调用此方法时集合中至少存在一个元素）。每个元素应该有 相同的概率 被返回。
    你必须实现类的所有函数，并满足每个函数的 平均 时间复杂度为 O(1) 。
*/
public class leetcode_380 {
    public static void main(String[] args) {

    }

}
class RandomizedSet {
    Map<Integer,Integer> map;
    List<Integer> list;
    Random random;
    public RandomizedSet() {
        map = new HashMap<>();
        list = new ArrayList<>();
        random = new Random();
    }

    public boolean insert(int val) {
        if (map.containsKey(val)){
            return false;
        }
        int index = list.size();
        list.add(val);
        map.put(val,index);
        return true;
    }

    public boolean remove(int val) {
        if (!map.containsKey(val)){
            return false;
        }
        int index =  map.get(val);
        int last = list.get(list.size()-1);
        list.set(index,last);
        map.put(index,last);
        list.remove(list.size()-1);
        map.remove(val);
        return true;
    }

    public int getRandom() {
        int randowIndex = random.nextInt(list.size());
        return list.get(randowIndex);
    }
}